#include <iostream>
#include <cmath>
using namespace std;
typedef long long ll;
const int N=1e6+10;
int a[N];
int st[N];
int b[N];
int idx=0;
int main()
{
    int n,k;
    cin>>n>>k;
    int p=pow(2,0);
    for(int i=2;i<=n;i++)
    {
        if(i-1==p)
        {
            idx++;
            p*=2;
        }
        a[i]=idx;
    }
    idx=0;
    int sum=0;
    for(int i=2;i<=n;i++)
    {
        sum+=a[i];
    }
    if(k>sum) cout<<-1;
    else
    {
        int num=sum-k;
        for(int i=n;i>=2;i--)
        {
            if(a[i]<=num)
            {
                num-=a[i];
                st[i]=1;
                b[idx]=i;
                idx++;
                //cout<<idx<<' ';
            }
        }
        for(int i=1;i<=n;i++)
        {
            if(st[i]==0) 
            {
                b[idx]=i;
                idx++;
               // cout<<idx<<' ';
            }
        }
        
        for(int i=idx-1;i>=0;i--)
        {
            cout<<b[i]<<' ';
        }
    }
    return 0;
}
